尝试在ruby脚本中使用roogem解析XLSX文件。在Excel中,日期以DDDDD.ttttt格式存储为float或整数,从1900-01-00(00no01)开始计算。因此,为了转换诸如40396之类的日期-您将使用1900-01-00+40396,您应该得到2010-10-15,但我得到的是2010-08-08。我正在使用active_support/time进行这样的计算:Time.new("1900-01-01")+40396.days我的计算有误还是主动支持有问题?我在Windows7+最新的active_supportgem(3.2.1)上运行ruby1.9.3
我知道如何将Rails中的表格导出到格式化的Excel文件:http://railscasts.com/episodes/362-exporting-csv-and-excel但是如何从控制台执行此操作。 最佳答案 使用连接到您的Heroku数据库herokupg:psql然后运行sql命令来获取csv文件,例如\copy(SELECT*FROMusers)TOdump.csvCSVDELIMITER','使用\q退出。执行命令后dump.csv将在您的本地环境中创建 关于ruby-
我正在处理潜在的巨大CSV文件,我想从我的Rails应用程序导出这些文件,并且由于它在Heroku上运行,我的想法是在生成这些CSV文件时将它们直接流式传输到S3。现在,我遇到了一个问题,因为Aws::S3需要一个文件才能执行上传,而在我的Rails应用程序中我想做类似的事情:S3.bucket('my-bucket').object('my-csv')我怎样才能做到这一点? 最佳答案 您可以使用s3分段上传,允许通过将大对象拆分为多个block来上传。https://docs.aws.amazon.com/AmazonS3/lat
我一直在阅读newruby2.0features,发现它会支持字节码导入/导出:Ruby2.0isexpectedtomakeitsimpletosavepre-compiledRubyscriptstobytecoderepresentationsandtothenrunthesedirectly.我已经安装了ruby-2.0.0-p0,但是我没有找到任何关于如何导出字节码的信息(或者一般的关于这方面的文档)。此功能是否已经实现,如果是,我该如何使用它?我也想知道一些细节。YARV字节码是否应该与平台无关?所有的gem都自动包含在字节码中吗? 最佳答案
我需要读取一个CSV文件,更新一个字段,然后保存更改。除了将我的更改保存到我正在更新的字段外,我一切正常:require'csv'@parsed_file=CSV::Reader.parse(File.open("#{RAILS_ROOT}/doc/some.csv"))@parsed_file.each_with_indexdo|row,x|address=row[5]l=Location.address_find(address)ifl!=nilputs"#{l.name}at#{l.address}"row[14]=l.store_codeputsrow[14]elseputs"
如何只解析CSV文件的第一行?我想确保文件中提供了所有适当的列,但不想处理整个文件。 最佳答案 一个更好的方法是简单地使用内置的Enumerable支持Ruby'sStandardLibraryCSVparser:headers=CSV.open('file.csv','r'){|csv|csv.first}该block将导致文件自动关闭,调用将返回已解析header的数组。 关于ruby-on-rails-如何只解析CSV文件的第一行?,我们在StackOverflow上找到一个类似的
我需要在解析CSV文件中的数据之前验证其中的header。#convertthedataintoanarrayofhashesCSV::Converters[:blank_to_nil]=lambdado|field|field&&field.empty??nil:fieldendcsv=CSV.new(file,:headers=>true,:header_converters=>:symbol,:converters=>[:all,:blank_to_nil])csv_data=csv.to_a.map{|row|row.to_hash}我知道我可以使用headers方法来获取标题
我正在使用Roogem解析Excel和Excelx文件。但我不确定如何写入这些文件。set_value(row,column,text)方法无效。代码@oo=Excelx.new('tes.xlsx')@oo.default_sheet=@oo.sheets.firstdefreturn_columnkeywords=["website","url"]keywords.eachdo|keyword|1.upto(@oo.last_column)do|n|data=@oo.cell(1,n)returnnifdata.downcase=~/#{keyword}/iendendenddef
我想知道如何在导入和解析CSV文件时更改它的编码。我有这段代码:csv=CSV.parse(output,:headers=>true,:col_sep=>";")csv.eachdo|row|row=row.to_hash.with_indifferent_accessinsert_data_method(row)end当我读取我的文件时,我得到这个错误:Encoding::CompatibilityErrorinFileImportingController#load_fileincompatiblecharacterencodings:ASCII-8BITandUTF-8我阅读了
在我的应用程序(Rails3.0.5、Ruby1.8.7)中,我创建了一个导入工具来从文件导入CSV数据。问题:我要求我的用户以UTF-8编码从Excel中导出CSV文件,但大多数时候他们并没有这么做。如何在导入前验证文件是否为UTF-8?否则导入将运行但会产生奇怪的结果。我使用FasterCSV导入。错误的CSV文件示例:;VallÈeduRhÙne;CÙteRotie;谢谢。 最佳答案 您可以使用CharlockHolmes,Ruby的字符编码检测库。https://github.com/brianmario/charlock_